# FPGA Design - the Making of an Intel 8086 Microprocessor with Modern Technology

**Independent Study / Special Problems** 

#### 1

2

# FPGA Design - the Making of an Intel 8086

# Microprocessor with Modern Technology

#### **Abstract**

The Intel 8086 microprocessor was first introduced in 1978. Since then the semiconductor industry has changed vastly from the old chip manufacturing techniques of the time. Today we can fit thousands of Intel 8086 microprocessors in the same size package with use of modern semiconductor techniques such as the ability to design with 22nm feature size and better yield from improved wafer quality. This paper examines how we can still learn from preceding technology with a more modern twist. By utilizing field programmable gate arrays, we can easily implement the same technology from the past and learn about architectures that are still relevant today.

#### **CONTENTS**

I

Introduction

| II    | Implementation Requirements                                       | 3 |  |
|-------|-------------------------------------------------------------------|---|--|
| Ш     | Procedure                                                         | 4 |  |
| IV    | Results                                                           | 5 |  |
| V     | Problems Faced & Troubleshooting                                  | 6 |  |
| VI    | Conclusion                                                        | 7 |  |
| Appe  | Appendix A: Full specifications for Altera DE0 development board: |   |  |
| Appe  | Appendix B: Available x86 Instructions on the Zet Processor:      |   |  |
| Refer | References                                                        |   |  |

#### I. Introduction

It was in the mid 1970s when Intel announced their latest project, the Intel 8086 - a 16-bit microprocessor capable of supporting up to a revolutionary 1 mega*byte* of address space and 64 kilo*bytes* of input/output. Gone were the days of simple computing in only 8-bits of freedom, this was the 70's and 16-bits were here to take over. Along with the increases in accessible memory and larger size ALU computations, Intel introduced a new type of architecture and instruction set known as x86, this new method of computing revolved around the use of registers that stored input and output data which could then have computations performed on them. This improvement has since paved the way for future computing by setting a standard on how the processor receives data and how the data can then be processed in a regular clock cycle. The 8086 supported 80 assembly instructions which also included instructions compatible with the older 8-bit processors so the older programs would still be backwards compatible with the new technology, this capability alone was one of the major reasons that large companies began transitioning to the new architecture which began a substantial drive to future 16-bit iterations of the processor.

The field-programmable gate array (FPGA) has been around since the 1980's, its purpose was to be able to easily create and prototype custom hardware without having to expend vast resources required for designing and manufacturing application-specific integrated circuits (ASICs). The FPGA accomplishes this by using "logic elements" (LE), a term that varies by manufacturer but is essentially the same, which is typically a circuit that consists of a lookup table for performing an array of logic operations, multiplexers and low level logic gates that can be configured in such a way as to create custom complex logic such as adders/subtractors or even be used for more simple XOR and NAND gates. A common structure of a logic element can be found in Figure 1, this one is from the Altera Cyclone III family. The elements are most often configured as a matrix with interconnects for inputs, outputs and configuration paths in between. In the last decade or so, improvements in silicon technologies have allowed FPGA manufacturers to greatly increase the number of logic elements on a chip into the hundreds of thousands and beyond which makes it possible to design hardware of almost the same complexity as modern ASICs.

After discovering an independent open source initiative, Zet Processor - a clone of the Intel 8086 hardware description by Zeus Gmez Marmolejo, it was determined that this project would make it possible so that the Intel 8086 microprocessor could be implemented onto a modern FPGA [2]. The project as a whole would encourage study



Fig. 1. Cyclone III Device Family LEs in Normal Mode [1]

in all areas of focus for a person with primary interests in Computer Architecture, Digital Systems Design, FPGAs, and Assembly programming. This project and study is something that can also be completed within the time frame of a typical academic semester.

# II. IMPLEMENTATION REQUIREMENTS

Through extensive research of various FPGA manufacturers and the different styles of development boards offered from a select number of companies, it was determined that an FPGA that is able to hold more than 9,000 LEs would be required to successfully implement the Intel 8086 microprocessor. As an added necessity, it was important to select a development board that would be able to handle the project inputs and outputs such as PS2 keyboard and VGA output in order to spend more time on the study and not building miscellaneous external hardware. From this research, it was determined that the Altera DE0 development board sufficiently met the project needs with over 15,000 LE's, a VGA port, a PS2 port, buttons, LEDs, switches, and USB interface. Another important addition to the board is its Secure Digital (SD) memory card slot which would allow for external flash memory storage of an operating system, full specifications for the Altera DE0 board can be found in Appendix.

Other components for the project include; an LCD monitor to visualize the system status, a PS2 keyboard to interact with the operating system, a computer with Linux to compile the processor and write the operating system to the memory card.

Since the study is sponsored by the Altera University Program, an Altera DE0 development board has been provided as well as an Altera DE0-Nano development boards at no cost. This makes the projects overall required budget \$0

since the devices come with the necessary software to program the FPGA and all of the other software packages used are open source.

#### III. PROCEDURE

The Zet Processor is more than just Verilog code for an Intel 8086 microprocessor, it also contains the necessary BIOS and drivers for treating the SD memory card as a mounted hard disc. The preliminary steps for installing the processor first include compiling the BIOS by running it through the Open Watcom compiler which takes the BIOS code written in C and compiles it into x86 Assembly optimized for 16-bit instructions [3]. We then take the BIOS assembly and convert it into hexadecimal by means of a simple file conversion script, this is now our ROM for placing onto the FPGA. The BIOS then gets placed onto the FPGA through running the DE0\_Control\_Panel, an example program that comes with the FPGA software, which allows for files to be placed directly onto the on-board flash memory. This is important because as the processor boots, it will automatically look at address 0x000000 for instructions on where to next proceed such as how to mount the operating system and ultimately boot it.

Since the processor runs 16-bit x86 it is necessary to choose a compatible operating system. This leaves a few options including MS-DOS 6.22, FreeDOS 1.1, and Microsoft Windows 3.0. MS-DOS was chosen due to its small file size and easy to work with command line interface, as an added bonus the copyright for MS-DOS has expired which makes it very easy and convenient to find the source code in various places on the Internet. To load the operating system, it was necessary to load the files exactly as described from the downloaded image. The process was accomplished by running dd if=./msdos.img of=/dev/sdc on a Linux computer, this instruction mounts the MS-DOS image byte-by-byte onto the SD memory card which is necessary for when the BIOS looks at a specific memory location to start the operating system.

In order to begin the process of loading the Zet Processor hardware onto the FPGA, it is first important to read the documentation and manuals for the Altera DE0 Development Board and accompanying Quartus II software manual.

The process for loading Verilog onto the device is fairly straightforward, that is to compile the Verilog code and debug any miscellaneous warnings and compilation errors and then to utilize the on-board programmer to load the code onto the device. When loading the code it is important to take note of the different ways in which the code can be loaded. If the code is loaded through the Joint Tag Action Group (JTAG) interface, it is important to note that

this only temporarily loads the hardware and all progress will be lost after powering down the device. This feature is due to the fact that JTAG is made for testing and only loads values directly into the flip-flops and accompanying hardware but does not save this setup data to the flash memory. Since this method only sets the hardware, it can load the hardware almost instantaneously. The other method for loading hardware is known as Active Serial programming (AS), this method requires that the FPGA device is placed into programming mode which can be done by flipping a switch placed on the development board. AS places the FPGA configuration data into FLASH memory which is read into the device at power up.

| Flow Summary                       |                                               |  |  |
|------------------------------------|-----------------------------------------------|--|--|
| Flow Status                        | Successful - Fri Mar 22 23:52:26 2013         |  |  |
| Quartus II 64-Bit Version          | 12.1 Build 243 01/31/2013 SP 1 SJ Web Edition |  |  |
| Revision Name                      | kotku                                         |  |  |
| Top-level Entity Name              | kotku                                         |  |  |
| Family                             | Cyclone III                                   |  |  |
| Device                             | EP3C16F484C6                                  |  |  |
| Timing Models                      | Final                                         |  |  |
| Total logic elements               | 8,434 / 15,408 ( 55 % )                       |  |  |
| Total combinational functions      | 7,858 / 15,408 ( 51 % )                       |  |  |
| Dedicated logic registers          | 2,952 / 15,408 ( 19 % )                       |  |  |
| Total registers                    | 2976                                          |  |  |
| Total pins                         | 154 / 347 ( 44 % )                            |  |  |
| Total virtual pins                 | 0                                             |  |  |
| Total memory bits                  | 74,547 / 516,096 ( 14 % )                     |  |  |
| Embedded Multiplier 9-bit elements | 2 / 112 ( 2 % )                               |  |  |
| Total PLLs                         | 1/4(25%)                                      |  |  |
| •                                  |                                               |  |  |

Fig. 2. Compilation results of the Zet Processor from Quartus II software.

# IV. RESULTS

After performing the necessary steps as described by the procedure, the processor is now fully functional and can run an operating system as shown in Figure 3. This was the primary objective for the project and is considered to define the project as an overall success. The next steps were to design presentation materials for demonstration, since MS-DOS includes a program called QBASIC which is a BASIC language interpreter based off of Microsoft's more popular software QuickBASIC, some demonstration programs were written to show off some of the processors capabilities such as the Hello World program and a small game for guessing a random number. The operating system also included some games which could be played through keyboard input such as Rogue, which is described as a crawling dungeon game with ASCII text based graphics that are easily displayed in terminal where the player has to fight off goblins only disguised as the letter "G" and collect coins throughout the map [4].



Fig. 3. FPGA loaded with an Intel 8086 microprocessor running MS-DOS 6.22

#### V. PROBLEMS FACED & TROUBLESHOOTING

The number one challenge in completing this study was a lack of full documentation and user base for the Zet Processor. It became evident very early on in research that this project would require extensive digging through the source code and custom modifications to get it to work with the Cyclone III device. The last update for the project was over a year ago and the online support forums provided little resource with many of the problems faced when trying to implement the processor. It was also difficult to determine which version of the processor was relevant to the documentation so it was assumed that most of what was found was obsolete or not correct.

Issues in implementing the processor involved problems with the BIOS not compiling due to Open Watcom not being correctly added to the system path, once this was resolved the BIOS compiled correctly. The installation document also does not make clear that it is necessary to convert the BIOS into hexadecimal, when this was done and added into the ROM the processor behaved correctly.

There were also some stability issues with the SD memory, the project site lists a way to mount MS-DOS to the SD card through a program known as Winimage but this failed multiple times and always left the processor hung up at different parts of the boot sequence. This was corrected by loading instead the image byte-by-byte in Linux as mentioned previously, which was not as simple as it sounds since there were also issues with the SD card not being formatted properly. It was finally fixed by formatting the card with all zeros and then the operating system began to work properly.

Lastly, once MS-DOS was finally operational after quite a few hours of debugging it was powered down for the

7

evening and then turned back on in the morning, the result was an error stating that the SD card had become corrupt. This was odd due to the fact that it was operational not but a few hours beforehand. After power cycling the device a few times and with feelings of great defeat that the processor was still not functional, a last ditch effort of removing the SD card and blowing air into the slot and placing the card back into the slot was attempted. The device was then powered back on and worked flawlessly.

# VI. CONCLUSION

One of the primary objectives for this study was to gain comprehensive knowledge of the inner working of FPGAs and x86 architecture. By working with the Zet Processor as a working clone of the Intel 8086 hardware it was possible to complete this research within the course of one academic semester. Through this research, it has become clear that a project of this complexity can adequately prepare a person to learn the inner workings of FPGAs. The process of compiling and debugging an early processor gives experience in how to manage a design where hardware may sometimes be limited. It also examines topics in low level device drivers and memory management. Working with the original x86 architecture from the 1970's provided great insight into its relation to the 32-bit and 64-bit versions of x86. It is very clear to see how the industry has changed so much during this time but yet, many of the artifacts from 16-bit architecture are still present in modern versions. Overall, the fact that technology from long ago can still be examined through more modern means such as through FPGAs allows for the technology to continue to be explored and aids in giving great experience in computer architecture design to students interested in pursuing this area of study.

#### ACKNOWLEDGMENT

The author would like to thank the Altera University Program [5] for providing development boards and necessary software for work on this area of study.

# APPENDIX A

FULL SPECIFICATIONS FOR ALTERA DE0 DEVELOPMENT BOARD:

FPGA

- Cyclone III 3C16 FPGA
- o 15,408 LEs
- 56 M9K Embedded Memory Blocks
- o 504K total RAM bits
- o 56 embedded multipliers
- o 4 PLLs
- o 346 user I/O pins
- o FineLine BGA 484-pin package

# Memory

- o SDRAM
  - One 8-Mbyte Single Data Rate Synchronous Dynamic RAM memory chip
- o Flash memory
  - 4-Mbyte NOR Flash memory
  - Support Byte (8-bits)/Word (16-bits) mode
- SD card socket
  - Provides both SPI and SD 1-bit mode SD Card access

# Interface

- o Built-in USB Blaster circuit
  - On-board USB Blaster for programming
  - Using the Altera EPM240 CPLD
- Altera Serial Configuration device
  - Altera EPCS4 serial EEPROM chip
- Pushbutton switches
  - 3 pushbutton switches
- Slide switches

- 10 Slide switches
- o General User Interfaces
  - 10 Green color LEDs
  - 4 seven-segment displays
- Clock inputs
  - 50-MHz oscillator
- VGA output
  - Uses a 4-bit resistor-network DAC
  - With 15-pin high-density D-sub connector
  - Supports up to 1280x1024 at 60-Hz refresh rate
- Serial ports
  - One RS-232 port (Without DB-9 serial connector)
  - One PS/2 port
- Two 40-pin expansion headers
  - 72 Cyclone III I/O pins, as well as 8 power and ground lines, are brought out to two 40-pin expansion connectors
  - 40-pin header is designed to accept a standard 40-pin ribbon cable used for IDE hard drives

# APPENDIX B

# AVAILABLE X86 INSTRUCTIONS ON THE ZET PROCESSOR:

# **Data transfer instructions**

mov, push/pop, in/out, lahf/sahf, lds/lea/les, pushf/popf, xchg, xlat

# **Arithmetic instructions**

aaa/aas, aam, aad, daa/das, cbw/cwd, inc, dec, add/adc, sub/sbb, mul/imul, div/idiv, neg, cmp

# Bitwise handling instructions

and/or, not, rcl, rcr, rol, ror, sal/shl, sar, shr, test, xor

# **Control transfer instructions**

call, ja/jnbe, jae/jnb/jnc, jb/jnae/jc, jbe/jna, jcxz, je/jz, jg/jnle, jge/jnl, jl/jnge, jle/jng, jne/jnz, jno, jnp/jpo, jns, jmp, jo, jp/jpe, js, loop, loope/loopz, loopne/loopz, ret

# String handling instructions

cmpsb/cmpsw, lodsb/lodswm, movsb/movsw, rep (pref), repe/repz (pref), repne/repnz (pref), scasb/scasw, stosb/stosw

# **Interrupt instructions**

int, into, iret

# Microprocessor control instructions

clc, cld, cli, cmc, hlt, nop, stc, std

# REFERENCES

- [1] Altera Corporation. (2012, Aug.) Cyclone III device handbook. [Online]. Available: http://www.altera.com/literature/hb/cyc3/cyclone3\_handbook.pdf
- [2] Z. G. Marmolejo. (2011, Feb.) Zet Processor Source Code. [Online]. Available: https://github.com/marmolejo/zet
- [3] Open Watcom. (2010, Jun.) Welcome to Open Watcom. [Online]. Available: http://www.openwatcom.org/index.php/Main\_Page
- [4] M. Toy and G. Wichman, "Rogue (video game)," 1980.
- [5] Altera Corporation. (2012, Aug.) Altera University Program Learning Through Innovation. [Online]. Available: http://www.altera.com/education/univ/unv-index.html